package com.mjf.datatype;

/**
 * 自动类型转换
 */
public class AutoConvert {
    public static void main(String[] args) {

        // 细节1：有多种类型的数据混合运算时，
        // 系统首先自动将所有数据转换成容量最大的那种数据类型，然后再进行计算
        int n1 = 10; // ok
//        float d1 = n1 + 1.1;  // 错误 n1 + 1.1 => 结果类型是 double
//        double d1 = n1 + 1.1; // 对 n1 + 1.1 => 结果类型是 double
        float d1 = n1 + 1.1F;   // 对 n1 + 1.1 => 结果类型是 float

        // 细节2: 当我们把精度(容量)大 的数据类型赋值给精度(容量)小 的数据类型时，就会报错，反之就会进行自动类型转换。
//        int n2 = 1.1; // 错误 double -> int

        // 细节3: (byte, short) 和 char之间不会相互自动转换
        // 当把具体数赋给 byte 时，(1)先判断该数是否在byte范围内，如果是就可以
        byte b1 = 10; // 对  , -128-127
        int n2 = 1; // n2 是int
//        byte b2 = n2; // 错误，原因：如果是变量赋值，判断类型

//        char c1 = b1; // 错误， 原因 byte 不能自动转成 char

        //细节4: byte，short，char  他们三者可以计算，在计算时首先转换为int类型
        byte b2 = 1;
        byte b3 = 2;
        short s1 = 1;
//        short s2 = b2 + s1; // 错, b2 + s1 => int
        int s2 = b2 + s1;   // 对, b2 + s1 => int

//        byte b4 = b2 + b3; // 错误: b2 + b3 => int

        // boolean 不参与转换
        boolean pass = true;
        // int num100 = pass;   // boolean 不参与类型的自动转换

        // 自动提升原则：表达式结果的类型自动提升为 操作数中最大的类型
        // 看一道题

        byte b4 = 1;
        short s3 = 100;
        int num200 = 1;
        float num300 = 1.1F;

        double num500 = b4 + s3 + num200 + num300; // float -> double
        System.out.println(num500);

    }
}
